Skill Development

প্র্যাকটিস প্রোজেক্টস

Ansible এর সাথে প্র্যাকটিস করার জন্য কিছু প্রকল্প আপনাকে অটোমেশন, কনফিগারেশন ম্যানেজমেন্ট এবং ক্লাউড ডিপ্লয়মেন্টের দক্ষতা বাড়াতে সাহায্য করবে। নিচে কিছু প্র্যাকটিস প্রকল্পের ধারণা দেওয়া হলো:

১. ওয়েব সার্ভার ডিপ্লয়মেন্ট

বিবরণ: একটি প্লেবুক তৈরি করুন যা একটি ওয়েব সার্ভার (যেমন Apache বা Nginx) ইনস্টল এবং কনফিগার করে। আপনি DNS কনফিগারেশন, SSL সার্টিফিকেট ইনস্টলেশন এবং ভার্চুয়াল হোস্ট সেটআপ করতে পারেন।

প্রয়োজনীয় উপাদান:

  • ইনভেন্টরি ফাইল
  • প্লেবুক (যেমন: web_server_deploy.yml)
  • টেমপ্লেট (যদি কাস্টম কনফিগারেশন ফাইল তৈরি করতে চান)

২. ডাটাবেস সেটআপ

বিবরণ: একটি প্লেবুক তৈরি করুন যা একটি ডাটাবেস সার্ভার (যেমন MySQL বা PostgreSQL) ইনস্টল করে এবং একটি নির্দিষ্ট ডাটাবেস ও ব্যবহারকারী তৈরি করে।

প্রয়োজনীয় উপাদান:

  • ইনভেন্টরি ফাইল
  • প্লেবুক (যেমন: database_setup.yml)
  • ভ্যারিয়েবল ফাইল (যেখানে ডাটাবেসের নাম এবং ব্যবহারকারীর তথ্য থাকবে)

৩. ক্লাউড ইনফ্রাস্ট্রাকচার অটোমেশন

বিবরণ: AWS, Azure বা GCP তে একটি VM তৈরি এবং কনফিগার করার জন্য একটি প্লেবুক তৈরি করুন। ডকার কন্টেইনারও রান করানো যেতে পারে।

প্রয়োজনীয় উপাদান:

  • ইনভেন্টরি ফাইল
  • প্লেবুক (যেমন: cloud_infra_automation.yml)
  • AWS CLI, Azure CLI বা GCP SDK কনফিগারেশন

৪. মাইক্রোসার্ভিস ডিপ্লয়মেন্ট

বিবরণ: বিভিন্ন মাইক্রোসার্ভিস তৈরি এবং ডিপ্লয় করতে একটি প্লেবুক তৈরি করুন। প্রতিটি সার্ভিসের জন্য আলাদা কন্টেইনার থাকতে পারে এবং একটি সিস্টেম যেখানে সব সার্ভিস একসাথে কাজ করে।

প্রয়োজনীয় উপাদান:

  • ইনভেন্টরি ফাইল
  • Dockerfile প্রতিটি সার্ভিসের জন্য
  • প্লেবুক (যেমন: microservices_deploy.yml)

৫. নেটওয়ার্ক ডিভাইস কনফিগারেশন

বিবরণ: Cisco বা Juniper ডিভাইসে কনফিগারেশন করার জন্য একটি প্লেবুক তৈরি করুন। VLAN তৈরি, ইন্টারফেস কনফিগারেশন, এবং অন্যান্য নেটওয়ার্ক সেটিংস করতে পারেন।

প্রয়োজনীয় উপাদান:

  • ইনভেন্টরি ফাইল
  • প্লেবুক (যেমন: network_config.yml)
  • ডিভাইসের তথ্য (IP, ইউজারনেম, পাসওয়ার্ড)

৬. CI/CD পাইপলাইন সেটআপ

বিবরণ: Jenkins বা GitLab CI/CD ব্যবহার করে একটি সিস্টেম তৈরি করুন যা কোড কমিট করার সাথে সাথে স্বয়ংক্রিয়ভাবে ডিপ্লয়মেন্ট করে।

প্রয়োজনীয় উপাদান:

  • প্লেবুক (যেমন: ci_cd_setup.yml)
  • ডকার কন্টেইনার বা VM এর জন্য রিসোর্স তৈরি
  • Jenkinsfile বা GitLab CI/CD কনফিগারেশন

৭. টেস্টিং এবং ডিবাগিং প্রকল্প

বিবরণ: আপনার তৈরি করা প্লেবুকগুলোকে টেস্ট করার জন্য Molecule এবং Testinfra ব্যবহার করুন। এটি আপনার স্ক্রিপ্টগুলোকে সঠিকভাবে কাজ করছে কিনা তা যাচাই করতে সাহায্য করবে।

প্রয়োজনীয় উপাদান:

  • Molecule কনফিগারেশন
  • Testinfra টেস্ট কেস

৮. Ansible Vault ব্যবহার করে নিরাপত্তা নিশ্চিত করা

বিবরণ: Ansible Vault ব্যবহার করে সংবেদনশীল তথ্য নিরাপদে সংরক্ষণ এবং পরিচালনা করার একটি প্রকল্প তৈরি করুন। এটি পাসওয়ার্ড এবং API কী এনক্রিপ্ট করার জন্য ব্যবহৃত হবে।

প্রয়োজনীয় উপাদান:

  • Vault ফাইল (যেমন: secrets.yml)
  • প্লেবুক (যেমন: secure_playbook.yml)

৯. কনফিগারেশন ম্যানেজমেন্ট সিস্টেম তৈরি

বিবরণ: বিভিন্ন সার্ভার এবং ডিভাইসগুলির জন্য একটি কেন্দ্রীয় কনফিগারেশন ম্যানেজমেন্ট সিস্টেম তৈরি করুন। এটি সকল সার্ভারের কনফিগারেশনকে একত্রে পরিচালনা করবে।

প্রয়োজনীয় উপাদান:

  • ইনভেন্টরি ফাইল
  • বিভিন্ন প্লেবুক (যেমন: config_management.yml)

১০. Documentation এবং Reporting

বিবরণ: আপনার প্লেবুক এবং রোলগুলো সম্পর্কে ডকুমেন্টেশন তৈরি করুন। এতে কিভাবে ব্যবহার করতে হবে, কিভাবে কনফিগার করতে হবে তা উল্লেখ থাকবে। এছাড়াও, রান করার পর রিপোর্ট তৈরি করতে পারবেন।

প্রয়োজনীয় উপাদান:

  • README ফাইল
  • রান রিপোর্ট জেনারেট করার জন্য একটি স্ক্রিপ্ট

উপসংহার

এই প্রকল্পগুলো Ansible ব্যবহার করে আপনার দক্ষতা এবং অভিজ্ঞতা বাড়ানোর জন্য চমৎকার সুযোগ প্রদান করে। এগুলোতে কাজ করার মাধ্যমে আপনি বাস্তব জগতের সমস্যাগুলি সমাধান করতে এবং Ansible এর পূর্ণ ক্ষমতা বুঝতে সক্ষম হবেন।

ওয়েব সার্ভার ডিপ্লয়মেন্ট

Ansible ব্যবহার করে একটি ওয়েব সার্ভার ডিপ্লয়মেন্ট করা একটি সহজ এবং কার্যকরী প্রক্রিয়া। নিচে, আমরা Apache এবং Nginx ওয়েব সার্ভার ডিপ্লয় করার জন্য একটি ধাপে ধাপে নির্দেশিকা এবং উদাহরণ দেব।

Apache ওয়েব সার্ভার ডিপ্লয়মেন্ট

ধাপ ১: ইনভেন্টরি ফাইল তৈরি করা

প্রথমে একটি ইনভেন্টরি ফাইল তৈরি করুন যাতে আপনার ওয়েব সার্ভার যেখানে ডিপ্লয় হবে সেই সার্ভারের তথ্য থাকবে।

inventory.ini:

[webservers]
192.168.1.10 ansible_user=your_user ansible_ssh_private_key_file=/path/to/your/private/key

ধাপ ২: প্লেবুক তৈরি করা

এখন Apache ইনস্টল এবং কনফিগার করার জন্য একটি Ansible প্লেবুক তৈরি করুন।

apache_deploy.yml:

---
- name: Deploy Apache Web Server
  hosts: webservers
  become: yes
  tasks:
    - name: Update apt package index
      apt:
        update_cache: yes

    - name: Install Apache
      apt:
        name: apache2
        state: present

    - name: Start Apache service
      service:
        name: apache2
        state: started
        enabled: yes

    - name: Copy custom index.html
      copy:
        src: index.html
        dest: /var/www/html/index.html
        owner: www-data
        group: www-data
        mode: '0644'

ধাপ ৩: কাস্টম HTML ফাইল তৈরি করা

এখন একটি কাস্টম index.html ফাইল তৈরি করুন যা আপনি Apache সার্ভারে কপি করবেন।

index.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Welcome to Ansible Apache!</title>
</head>
<body>
    <h1>Hello, World!</h1>
    <p>This page was deployed using Ansible.</p>
</body>
</html>

ধাপ ৪: প্লেবুক রান করা

এখন, আপনার প্লেবুক রান করার জন্য নিচের কমান্ড ব্যবহার করুন:

ansible-playbook -i inventory.ini apache_deploy.yml

Nginx ওয়েব সার্ভার ডিপ্লয়মেন্ট

ধাপ ১: ইনভেন্টরি ফাইল তৈরি করা

Nginx ডিপ্লয় করার জন্য একই ইনভেন্টরি ফাইল ব্যবহার করতে পারেন।

inventory.ini:

[webservers]
192.168.1.10 ansible_user=your_user ansible_ssh_private_key_file=/path/to/your/private/key

ধাপ ২: প্লেবুক তৈরি করা

এখন Nginx ইনস্টল এবং কনফিগার করার জন্য একটি Ansible প্লেবুক তৈরি করুন।

nginx_deploy.yml:

---
- name: Deploy Nginx Web Server
  hosts: webservers
  become: yes
  tasks:
    - name: Update apt package index
      apt:
        update_cache: yes

    - name: Install Nginx
      apt:
        name: nginx
        state: present

    - name: Start Nginx service
      service:
        name: nginx
        state: started
        enabled: yes

    - name: Copy custom index.html
      copy:
        src: index.html
        dest: /var/www/html/index.html
        owner: www-data
        group: www-data
        mode: '0644'

ধাপ ৩: কাস্টম HTML ফাইল তৈরি করা

আপনার Nginx সার্ভারের জন্য একই কাস্টম index.html ফাইল ব্যবহার করতে পারেন।

ধাপ ৪: প্লেবুক রান করা

Nginx প্লেবুক রান করার জন্য নিচের কমান্ড ব্যবহার করুন:

ansible-playbook -i inventory.ini nginx_deploy.yml

সংক্ষেপে

  • Apache বা Nginx ডিপ্লয় করতে Ansible প্লেবুক ব্যবহার করা হয়, যা ওয়েব সার্ভার ইনস্টল, কনফিগার এবং কাস্টম HTML ফাইল কপি করতে সাহায্য করে।
  • আপনার ইনভেন্টরি ফাইল, প্লেবুক এবং কাস্টম HTML ফাইল তৈরি করতে হয়, তারপর Ansible কমান্ড দিয়ে প্লেবুক রান করতে হয়।
  • এটি একটি কার্যকরী এবং অটোমেটেড পদ্ধতি যা দ্রুত এবং নির্ভরযোগ্যভাবে ওয়েব সার্ভার ডিপ্লয় করতে সহায়ক।

এভাবে, আপনি সহজেই Ansible ব্যবহার করে আপনার নেটওয়ার্কে একাধিক সার্ভারে ওয়েব সার্ভার ডিপ্লয় করতে পারেন।

মাল্টি-টায়ার অ্যাপ্লিকেশন ডিপ্লয়মেন্ট

মাল্টি-টায়ার অ্যাপ্লিকেশন ডিপ্লয়মেন্ট হল একটি প্রক্রিয়া যেখানে একটি অ্যাপ্লিকেশনকে বিভিন্ন স্তরে ভাগ করা হয়, যেমন প্রেজেন্টেশন লেয়ার, অ্যাপ্লিকেশন লেয়ার এবং ডেটাবেস লেয়ার। এই পদ্ধতিতে প্রতিটি স্তর আলাদাভাবে পরিচালিত ও স্কেল করা যায়। নিচে মাল্টি-টায়ার অ্যাপ্লিকেশন ডিপ্লয়মেন্টের প্রক্রিয়া, উপকারিতা এবং উদাহরণ উল্লেখ করা হলো।

মাল্টি-টায়ার অ্যাপ্লিকেশন আর্কিটেকচার

প্রেজেন্টেশন লেয়ার (Presentation Layer):

  • এটি ইউজার ইন্টারফেস (UI) স্তর যেখানে ব্যবহারকারীরা অ্যাপ্লিকেশনটির সাথে যোগাযোগ করে। সাধারণত এটি ওয়েব ব্রাউজার বা মোবাইল অ্যাপ্লিকেশনের মাধ্যমে অ্যাক্সেস করা হয়।

অ্যাপ্লিকেশন লেয়ার (Application Layer):

  • এটি ব্যবসায়িক লজিক এবং অ্যাপ্লিকেশন কার্যকারিতা নিয়ে কাজ করে। এখানে সার্ভার এবং ব্যাকএন্ড প্রোগ্রাম থাকে।

ডেটাবেস লেয়ার (Database Layer):

  • এখানে ডেটা সংরক্ষিত হয়। সাধারণত এখানে রিলেশনাল ডেটাবেস (যেমন MySQL, PostgreSQL) বা নন-রিলেশনাল ডেটাবেস (যেমন MongoDB) ব্যবহৃত হয়।

মাল্টি-টায়ার ডিপ্লয়মেন্টের প্রক্রিয়া

১. আর্কিটেকচার ডিজাইন

  • প্রথমে অ্যাপ্লিকেশনটির আর্কিটেকচার ডিজাইন করুন, যেখানে প্রতিটি স্তরের জন্য পৃথক সার্ভার বা ক্লাউড পরিষেবা নির্ধারণ করবেন।

২. পরিবেশ সেটআপ

  • Infrastructure: আপনার জন্য প্রয়োজনীয় সিস্টেম রিসোর্সগুলি (EC2, Azure VMs, DigitalOcean Droplets, ইত্যাদি) প্রস্তুত করুন।
  • Networking: সঠিক নেটওয়ার্ক কনফিগারেশন সেট আপ করুন যাতে প্রতিটি স্তর একে অপরের সাথে যোগাযোগ করতে পারে।

৩. অ্যাপ্লিকেশন ডিপ্লয়মেন্ট

প্রেজেন্টেশন লেয়ার:

  • আপনার UI কোড (HTML, CSS, JavaScript) ডিপ্লয় করুন। উদাহরণস্বরূপ, Nginx বা Apache সার্ভার ব্যবহার করে।

অ্যাপ্লিকেশন লেয়ার:

  • ব্যাকএন্ড লজিক (যেমন Node.js, Python Flask, Java Spring) সার্ভারে ডিপ্লয় করুন। এটি REST API বা GraphQL API সরবরাহ করতে পারে।

ডেটাবেস লেয়ার:

  • ডেটাবেস সার্ভার সেট আপ করুন এবং আপনার ডেটাবেস স্কিমা তৈরি করুন। সাধারণত SQL বা NoSQL ডেটাবেস ব্যবহার করা হয়।

৪. সিকিউরিটি কনফিগারেশন

  • প্রতিটি স্তরের মধ্যে নিরাপত্তা কনফিগারেশন সেট আপ করুন, যেমন ফায়ারওয়াল নিয়ম, এনক্রিপশন, এবং অ্যাক্সেস কন্ট্রোল।

৫. মনিটরিং এবং স্কেলিং

  • অ্যাপ্লিকেশন মনিটরিং টুল (যেমন Prometheus, Grafana) ব্যবহার করুন। প্রয়োজন হলে স্কেলিং কনফিগার করুন যাতে ট্রাফিক বৃদ্ধি পেলে অ্যাপ্লিকেশনটি সক্ষম থাকে।

মাল্টি-টায়ার অ্যাপ্লিকেশনের উপকারিতা

  1. সুবিধাজনক স্কেলিং: প্রতিটি স্তর আলাদাভাবে স্কেল করা যায়।
  2. সার্ভিসের বিভাজন: বিভিন্ন স্তরের মধ্যে বিভাজন থাকা নিরাপত্তা ও ব্যবস্থাপনাকে সহজ করে।
  3. সুন্দর ডিজাইন: কোড পুনঃব্যবহারের সুবিধা এবং উন্নত করার ক্ষেত্রে সহজতা।
  4. সহজ রক্ষণাবেক্ষণ: সমস্যা চিহ্নিতকরণ এবং মেরামত করা সহজ।

উপসংহার

মাল্টি-টায়ার অ্যাপ্লিকেশন ডিপ্লয়মেন্ট একটি শক্তিশালী পদ্ধতি যা স্কেলেবিলিটি, নিরাপত্তা এবং রক্ষণাবেক্ষণের সুবিধা প্রদান করে। উপরের ধাপগুলি অনুসরণ করে আপনি সহজেই একটি মাল্টি-টায়ার অ্যাপ্লিকেশন ডিপ্লয় করতে পারেন।

নেটওয়ার্ক ডিভাইস কনফিগারেশন

Ansible ব্যবহার করে নেটওয়ার্ক ডিভাইস কনফিগারেশন একটি অত্যন্ত কার্যকরী এবং সহজ প্রক্রিয়া। এটি আপনাকে নেটওয়ার্ক ডিভাইস যেমন Cisco, Juniper, Arista, এবং অন্যান্য নেটওয়ার্ক হার্ডওয়্যারের কনফিগারেশন স্বয়ংক্রিয়ভাবে সম্পাদন করতে সহায়তা করে। চলুন, কিভাবে Ansible এর মাধ্যমে নেটওয়ার্ক ডিভাইস কনফিগার করা যায় তা দেখি।

প্রয়োজনীয়তা

  1. Ansible ইনস্টলেশন: আপনার সিস্টেমে Ansible ইনস্টল থাকতে হবে।
  2. নেটওয়ার্ক ডিভাইসের অ্যাক্সেস: SSH বা অন্য কোনো প্রোটোকল মাধ্যমে নেটওয়ার্ক ডিভাইসে লগ ইন করার জন্য সঠিক অনুমতি থাকতে হবে।
  3. প্লেবুক: আপনার কনফিগারেশন প্লেবুক তৈরি করতে হবে, যেখানে নেটওয়ার্ক ডিভাইসের কনফিগারেশন উল্লেখ করা হবে।
  4. ইনভেন্টরি ফাইল: নেটওয়ার্ক ডিভাইসের তথ্য সংরক্ষণের জন্য একটি ইনভেন্টরি ফাইল তৈরি করতে হবে।

উদাহরণ: Cisco IOS ডিভাইসে কনফিগারেশন

১. ইনভেন্টরি ফাইল তৈরি করা

আপনার নেটওয়ার্ক ডিভাইসের তথ্য সংরক্ষণের জন্য একটি ইনভেন্টরি ফাইল তৈরি করুন:

# inventory_cisco.yml
all:
  children:
    cisco_ios:
      hosts:
        ios_device_1:
          ansible_host: 192.168.1.1
          ansible_user: admin
          ansible_password: your_password
          ansible_network_os: ios

২. প্লেবুক তৈরি করা

এখন একটি প্লেবুক তৈরি করুন যা Cisco IOS ডিভাইসে কনফিগারেশন সম্পন্ন করবে:

# ios_config_playbook.yml
---
- name: Configure Cisco IOS device
  hosts: cisco_ios
  gather_facts: no
  tasks:
    - name: Configure hostname
      ios_config:
        lines:
          - hostname Ansible_Router

    - name: Create VLAN 10
      ios_config:
        lines:
          - vlan 10
          - name VLAN10

    - name: Configure interface
      ios_config:
        lines:
          - interface GigabitEthernet0/1
          - description Connected to Internet
          - no shutdown

    - name: Save the configuration
      ios_config:
        save: yes

ব্যাখ্যা

  • gather_facts: no সেট করা হয়েছে কারণ নেটওয়ার্ক ডিভাইসে ফ্যাক্টস সংগ্রহ করার প্রয়োজন নেই।
  • ios_config: এটি Cisco IOS ডিভাইসে কনফিগারেশন প্রয়োগ করার জন্য ব্যবহৃত হয়।
    • lines: এখানে ডিভাইসে কোন কোন কনফিগারেশন প্রয়োগ করতে চান তা উল্লেখ করা হয়েছে।

৩. প্লেবুক চালানো

এখন আপনি এই প্লেবুকটি চালাতে পারেন নিচের কমান্ডের মাধ্যমে:

ansible-playbook -i inventory_cisco.yml ios_config_playbook.yml --ask-vault-pass

৪. নেটওয়ার্ক ডিভাইসে Juniper কনফিগারেশন

ইনভেন্টরি ফাইল তৈরি করা

Juniper ডিভাইসের জন্য ইনভেন্টরি ফাইল তৈরি করুন।

# inventory_juniper.yml
all:
  children:
    juniper:
      hosts:
        juniper_device_1:
          ansible_host: 192.168.2.1
          ansible_user: admin
          ansible_password: your_password
          ansible_network_os: junos

Juniper ডিভাইসে কনফিগারেশন প্লেবুক

Juniper ডিভাইসে কনফিগারেশন করার জন্য একটি প্লেবুক তৈরি করুন।

# junos_config_playbook.yml
---
- name: Configure Juniper device
  hosts: juniper
  gather_facts: no
  tasks:
    - name: Configure hostname
      junos_config:
        lines:
          - set system host-name Ansible_Router

    - name: Create VLAN 10
      junos_config:
        lines:
          - set vlans VLAN10 vlan-id 10

    - name: Configure interface
      junos_config:
        lines:
          - set interfaces ge-0/0/0 description "Connected to Internet"
          - set interfaces ge-0/0/0 enable

    - name: Commit the configuration
      junos_config:
        commit: yes

৫. প্লেবুক চালানো

এখন আপনি এই প্লেবুকটি চালাতে পারেন নিচের কমান্ডের মাধ্যমে:

ansible-playbook -i inventory_juniper.yml junos_config_playbook.yml --ask-vault-pass

কনফিগারেশন টাস্কে ব্যবহৃত অন্যান্য Ansible মডিউল

  • ios_command: Cisco IOS ডিভাইসে সরাসরি কমান্ড চালানোর জন্য।
  • nxos_config: Cisco NX-OS ডিভাইসে কনফিগারেশন করার জন্য।
  • junos_command: Juniper ডিভাইসে সরাসরি কমান্ড চালানোর জন্য।

নেটওয়ার্ক কনফিগারেশনের সেরা অভ্যাস

  1. নেটওয়ার্ক কনফিগারেশন ব্যাকআপ: পরিবর্তন করার আগে সব সময় ব্যাকআপ নিতে ভুলবেন না।
  2. প্রকৃত ডিভাইসে পরীক্ষা করা: কোনও পরিবর্তন করার আগে ড্রাই রান বা ল্যাব পরিবেশে পরীক্ষা করুন।
  3. নথিপত্র তৈরি: কনফিগারেশন পরিবর্তনের সকল নথিপত্র সংরক্ষণ করুন।
  4. সংবেদনশীল তথ্য এনক্রিপ্ট করা: Ansible Vault ব্যবহার করে পাসওয়ার্ড এবং সংবেদনশীল তথ্য সুরক্ষিত করুন।

উপসংহার

Ansible নেটওয়ার্ক ডিভাইস কনফিগারেশনের জন্য একটি শক্তিশালী এবং কার্যকরী টুল। এটি আপনাকে স্বয়ংক্রিয়ভাবে নেটওয়ার্ক ডিভাইস কনফিগার, পরিচালনা এবং অটোমেট করতে সক্ষম করে। Ansible ব্যবহার করে আপনি নিরাপদ এবং কার্যকরীভাবে নেটওয়ার্ক ডিভাইস পরিচালনা করতে পারবেন।

ডকার কন্টেইনার ম্যানেজমেন্ট

Docker কন্টেইনার ম্যানেজমেন্ট হলো Docker পরিবেশে কন্টেইনার তৈরি, পরিচালনা এবং মেইনটেন করার প্রক্রিয়া। এটি আপনার অ্যাপ্লিকেশনগুলোকে আলাদা কনটেইনারে চালানোর সুবিধা দেয়, যা তাদের ইনস্টলেশন, কনফিগারেশন, আপডেট এবং মেইনটেইন করা সহজ করে তোলে। এখানে আমরা Docker কন্টেইনার ম্যানেজমেন্টের বিভিন্ন দিক নিয়ে আলোচনা করবো।

১. Docker কন্টেইনার তৈরি করা

কন্টেইনার তৈরি করতে আপনি Docker ইমেজ ব্যবহার করেন। নিচে একটি সাধারণ কমান্ড দেয়া হলো:

docker run -d --name my_container nginx

এখানে:

  • -d: কন্টেইনারটি ব্যাকগ্রাউন্ডে চালু করবে।
  • --name my_container: কন্টেইনারের নাম my_container হিসেবে সেট করবে।
  • nginx: কন্টেইনারে ব্যবহার করা হবে nginx ইমেজ।

২. কন্টেইনারের তালিকা দেখা

চালু কন্টেইনারগুলোর তালিকা দেখতে:

docker ps

যদি আপনি সমস্ত কন্টেইনার (চালু এবং থামানো) দেখতে চান:

docker ps -a

৩. কন্টেইনার থামানো

কোনো কন্টেইনার থামাতে:

docker stop my_container

৪. কন্টেইনার পুনরায় চালু করা

থামানো কন্টেইনার পুনরায় চালু করতে:

docker start my_container

৫. কন্টেইনার ডিবাগিং

কন্টেইনারের ভিতরে প্রবেশ করতে এবং সেটির শেল ব্যবহার করতে:

docker exec -it my_container /bin/bash

৬. কন্টেইনার মুছে ফেলা

কোনো কন্টেইনার মুছে ফেলতে:

docker rm my_container

এটি একটি থামানো কন্টেইনারের জন্য কাজ করে। যদি আপনি একটি চালু কন্টেইনার মুছে ফেলতে চান, প্রথমে সেটি থামাতে হবে।

৭. কন্টেইনার ইমেজের তালিকা দেখা

বর্তমানে আপনার সিস্টেমে ডাউনলোড করা ইমেজগুলো দেখতে:

docker images

৮. কন্টেইনার ইমেজ মুছে ফেলা

যেকোনো ইমেজ মুছে ফেলতে:

docker rmi <image_id>

৯. কন্টেইনার আপডেট করা

Docker কন্টেইনার আপডেট করার জন্য নতুন ইমেজ ডাউনলোড করে এবং পুরনো কন্টেইনারকে নতুন ইমেজ দিয়ে পুনরায় তৈরি করতে হবে। উদাহরণস্বরূপ, একটি কন্টেইনারকে আপডেট করার জন্য:

docker stop my_container
docker rm my_container
docker run -d --name my_container nginx:latest

১০. Docker Compose ব্যবহার করা

যদি আপনার একটি অ্যাপ্লিকেশন বিভিন্ন কন্টেইনারে রান করে, তাহলে Docker Compose ব্যবহার করা একটি ভালো পদ্ধতি। Docker Compose YAML ফাইলের মাধ্যমে একসাথে বিভিন্ন কন্টেইনার পরিচালনা করতে পারে।

docker-compose.yml উদাহরণ:

version: '3'
services:
  web:
    image: nginx
    ports:
      - "80:80"
  
  db:
    image: mysql
    environment:
      MYSQL_ROOT_PASSWORD: example

Compose ফাইলটি ব্যবহার করে কন্টেইনার চালাতে:

docker-compose up -d

১১. কন্টেইনার লগ দেখা

কন্টেইনারের লগ দেখতে:

docker logs my_container

সংক্ষেপে

Docker কন্টেইনার ম্যানেজমেন্ট একটি সহজ এবং কার্যকরী প্রক্রিয়া যা আপনাকে বিভিন্ন অ্যাপ্লিকেশন আলাদা কন্টেইনারে চালানোর সুবিধা দেয়। এটি কন্টেইনার তৈরি, থামানো, পুনরায় চালু করা, মুছে ফেলা, এবং লগ পরিচালনা করার ক্ষমতা দেয়। Docker Compose এর মাধ্যমে আপনি একসাথে একাধিক কন্টেইনার পরিচালনা করতে পারেন, যা আপনার ডেভেলপমেন্ট ও ডিপ্লয়মেন্ট প্রক্রিয়াকে আরও দক্ষ করে তোলে। Docker কন্টেইনার ব্যবস্থাপনা ব্যবহারের মাধ্যমে আপনি সিস্টেমের স্থিতিশীলতা এবং কার্যকারিতা বাড়াতে পারবেন।

আরও দেখুন...

Promotion